Brijesh's Git Server — watchman @ 4e2b931a2481f38d8de8cc6e6025d60c6ac9a3d9

observability tool, needs to be rewritten once identity is stable

client/src/pages/projects/[id]/delete.tsx (view raw)

 1
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
import { DeleteProject, GetProjectById, ListProjects } from "@/api/projects";
import { PrimaryButton } from "@/components/Button";
import MainLayout from "@/components/MainLayout";
import Head from "next/head";
import { useRouter } from "next/router";
import { useEffect, useState } from "react";

const ProjectDeletePage = () => {
  const router = useRouter();
  const { id } = router.query;

  const [project, setProject] = useState<any>();
  const [apiResponse, setApiResponse] = useState<any>();

  useEffect(() => {
    GetProjectById(id ? id.toString() : "", setProject);
  }, [id]);

  function deleteProject() {
    let project = { ID: id ? id.toString() : "" };

    DeleteProject(project, setApiResponse);
  }

  useEffect(() => {
    apiResponse && apiResponse.status === "OK" && router.push("/projects");
  }, [apiResponse]);

  return (
    <MainLayout>
      <Head>
        <title>Delete Project | Watchman</title>
      </Head>
      <div className="mb-4 flex justify-between items-center uppercase">
        {project?.data?.name && (
          <h1 className="text-xl font-medium">{project.data.name}</h1>
        )}
      </div>
      {project && project.data && project.data.name && (
        <p>Are you sure you want to delete this {project.data.name} project?</p>
      )}
      <div className="my-4 flex gap-2">
        <PrimaryButton
          text="Delete"
          intent="danger"
          onClick={() => deleteProject()}
        />
        <PrimaryButton text="Cancel" onClick={() => router.push("/projects")} />
      </div>
    </MainLayout>
  );
};
export default ProjectDeletePage;